Autogenerated HTML docs for v2.33.0-591-gddb10 
diff --git a/RelNotes/2.34.0.txt b/RelNotes/2.34.0.txt index 7ce5ab7..fa8eced 100644 --- a/RelNotes/2.34.0.txt +++ b/RelNotes/2.34.0.txt 
@@ -48,6 +48,14 @@  entire directory outside the sparse cone to be removed, which is  especially useful when the sparse patterns change.   + * Taking advantage of the CGI interface, http-backend has been + updated to enable protocol v2 automatically when the other side + asks for it. + + * The credential-cache helper has been adjusted to Windows. + + * The error in "git help no-such-git-command" is handled better. +    Performance, Internal Implementation, Development Support etc.   @@ -119,6 +127,9 @@  ask the file descriptors open for packfiles to be closed immediately  before spawning commands that may trigger auto-gc.   + * An oddball OPTION_ARGUMENT feature has been removed from the + parse-options API. +    Fixes since v2.33  ----------------- @@ -245,6 +256,17 @@  subsystem has been cleaned up.  (merge 35cf94eaf6 rs/no-mode-to-open-when-appending later to maint).   + * "git update-ref --stdin" failed to flush its output as needed, + which potentially led the conversation to a deadlock. + (merge 7c1200745b ps/update-ref-batch-flush later to maint). + + * When "git am --abort" fails to abort correctly, it still exited + with exit status of 0, which has been corrected. + (merge c5ead19ea2 en/am-abort-fix later to maint). + + * Correct nr and alloc members of strvec struct to be of type size_t. + (merge 8d133a4653 jk/strvec-typefix later to maint). +  * Other code cleanup, docfix, build fix, etc.  (merge 1d9c8daef8 ab/bundle-doc later to maint).  (merge 81483fe613 en/merge-strategy-docs later to maint). @@ -276,3 +298,8 @@  (merge 92a5d1c9b4 jc/prefix-filename-allocates later to maint).  (merge d9a65b6c0a rs/setup-use-xopen-and-xdup later to maint).  (merge e8f55568de jk/t5562-racefix later to maint). + (merge 8f0f110156 rs/drop-core-compression-vars later to maint). + (merge b6d8887d3d ma/doc-git-version later to maint). + (merge 66c0c44df6 cb/plug-leaks-in-alloca-emu-users later to maint). + (merge afb32e8101 kz/revindex-comment-fix later to maint). + (merge ae578de926 po/git-config-doc-mentions-help-c later to maint). 
diff --git a/git-am.html b/git-am.html index 8795488..81c8e46 100644 --- a/git-am.html +++ b/git-am.html 
@@ -1092,6 +1092,8 @@  <dd>   <p>   Restore the original branch and abort the patching operation.  + Revert contents of files involved in the am operation to their  + pre-am state.   </p>   </dd>   <dt class="hdlist1">  @@ -1207,7 +1209,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-05-16 16:01:05 PDT  + 2021-09-23 14:33:59 PDT   </div>   </div>   </body>  
diff --git a/git-am.txt b/git-am.txt index 8714dfc..0a4a984 100644 --- a/git-am.txt +++ b/git-am.txt 
@@ -178,6 +178,8 @@    --abort:: 	Restore the original branch and abort the patching operation. +	Revert contents of files involved in the am operation to their +	pre-am state.    --quit:: 	Abort the patching operation but keep HEAD and the index 
diff --git a/git-config.html b/git-config.html index 47ed86f..a913156 100644 --- a/git-config.html +++ b/git-config.html 
@@ -837,6 +837,8 @@  </li>   </ul></div>   <div class="paragraph"><p>On success, the command returns the exit code 0.</p></div>  +<div class="paragraph"><p>A list of all available configuration variables can be obtained using the  +<code>git help --config</code> command.</p></div>   </div>   </div>   <div class="sect1">  @@ -10445,7 +10447,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-08-04 00:06:05 PDT  + 2021-09-23 14:33:59 PDT   </div>   </div>   </body>  
diff --git a/git-config.txt b/git-config.txt index 2dc4bae..992225f 100644 --- a/git-config.txt +++ b/git-config.txt 
@@ -71,6 +71,9 @@    On success, the command returns the exit code 0.   +A list of all available configuration variables can be obtained using the +`git help --config` command. +  [[OPTIONS]]  OPTIONS  ------- 
diff --git a/git-http-backend.html b/git-http-backend.html index 24fdf1d..d4a9e22 100644 --- a/git-http-backend.html +++ b/git-http-backend.html 
@@ -761,7 +761,9 @@  clients accessing the repository over http:// and https:// protocols.   The program supports clients fetching using both the smart HTTP protocol   and the backwards-compatible dumb HTTP protocol, as well as clients  -pushing using the smart HTTP protocol.</p></div>  +pushing using the smart HTTP protocol. It also supports Git&#8217;s  +more-efficient "v2" protocol if properly configured; see the  +discussion of <code>GIT_PROTOCOL</code> in the ENVIRONMENT section below.</p></div>   <div class="paragraph"><p>It verifies that the directory has the magic file   "git-daemon-export-ok", and it will refuse to export any Git directory   that hasn&#8217;t explicitly been marked for export this way (unless the  @@ -847,7 +849,19 @@  <div class="content">   <pre><code>SetEnv GIT_PROJECT_ROOT /var/www/git   SetEnv GIT_HTTP_EXPORT_ALL  -ScriptAlias /git/ /usr/libexec/git-core/git-http-backend/</code></pre>  +ScriptAlias /git/ /usr/libexec/git-core/git-http-backend/  +  +# This is not strictly necessary using Apache and a modern version of  +# git-http-backend, as the webserver will pass along the header in the  +# environment as HTTP_GIT_PROTOCOL, and http-backend will copy that into  +# GIT_PROTOCOL. But you may need this line (or something similar if you  +# are using a different webserver), or if you want to support older Git  +# versions that did not do that copying.  +#  +# Having the webserver set up GIT_PROTOCOL is perfectly fine even with  +# modern versions (and will take precedence over HTTP_GIT_PROTOCOL,  +# which means it can be used to override the client's request).  +SetEnvIf Git-Protocol ".*" GIT_PROTOCOL=$0</code></pre>   </div></div>   <div class="paragraph"><p>To enable anonymous read access but authenticated write access,   require authorization for both the initial ref advertisement (which we  @@ -1060,6 +1074,15 @@  a repository with an extremely large number of refs. The value can be   specified with a unit (e.g., <code>100M</code> for 100 megabytes). The default is   10 megabytes.</p></div>  +<div class="paragraph"><p>Clients may probe for optional protocol capabilities (like the v2  +protocol) using the <code>Git-Protocol</code> HTTP header. In order to support  +these, the contents of that header must appear in the <code>GIT_PROTOCOL</code>  +environment variable. Most webservers will pass this header to the CGI  +via the <code>HTTP_GIT_PROTOCOL</code> variable, and <code>git-http-backend</code> will  +automatically copy that to <code>GIT_PROTOCOL</code>. However, some webservers may  +be more selective about which headers they&#8217;ll pass, in which case they  +need to be configured explicitly (see the mention of <code>Git-Protocol</code> in  +the Apache config from the earlier EXAMPLES section).</p></div>   <div class="paragraph"><p>The backend process sets GIT_COMMITTER_NAME to <em>$REMOTE_USER</em> and   GIT_COMMITTER_EMAIL to <em>${REMOTE_USER}@http.${REMOTE_ADDR}</em>,   ensuring that any reflogs created by <em>git-receive-pack</em> contain some  @@ -1079,7 +1102,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2020-03-10 15:02:33 PDT  + 2021-09-23 14:33:59 PDT   </div>   </div>   </body>  
diff --git a/git-http-backend.txt b/git-http-backend.txt index 558966a..0c5c0dd 100644 --- a/git-http-backend.txt +++ b/git-http-backend.txt 
@@ -16,7 +16,9 @@  clients accessing the repository over http:// and https:// protocols.  The program supports clients fetching using both the smart HTTP protocol  and the backwards-compatible dumb HTTP protocol, as well as clients -pushing using the smart HTTP protocol. +pushing using the smart HTTP protocol. It also supports Git's +more-efficient "v2" protocol if properly configured; see the +discussion of `GIT_PROTOCOL` in the ENVIRONMENT section below.    It verifies that the directory has the magic file  "git-daemon-export-ok", and it will refuse to export any Git directory @@ -77,6 +79,18 @@  SetEnv GIT_PROJECT_ROOT /var/www/git  SetEnv GIT_HTTP_EXPORT_ALL  ScriptAlias /git/ /usr/libexec/git-core/git-http-backend/ + +# This is not strictly necessary using Apache and a modern version of +# git-http-backend, as the webserver will pass along the header in the +# environment as HTTP_GIT_PROTOCOL, and http-backend will copy that into +# GIT_PROTOCOL. But you may need this line (or something similar if you +# are using a different webserver), or if you want to support older Git +# versions that did not do that copying. +# +# Having the webserver set up GIT_PROTOCOL is perfectly fine even with +# modern versions (and will take precedence over HTTP_GIT_PROTOCOL, +# which means it can be used to override the client's request). +SetEnvIf Git-Protocol ".*" GIT_PROTOCOL=$0  ----------------------------------------------------------------  +  To enable anonymous read access but authenticated write access, @@ -264,6 +278,16 @@  specified with a unit (e.g., `100M` for 100 megabytes). The default is  10 megabytes.   +Clients may probe for optional protocol capabilities (like the v2 +protocol) using the `Git-Protocol` HTTP header. In order to support +these, the contents of that header must appear in the `GIT_PROTOCOL` +environment variable. Most webservers will pass this header to the CGI +via the `HTTP_GIT_PROTOCOL` variable, and `git-http-backend` will +automatically copy that to `GIT_PROTOCOL`. However, some webservers may +be more selective about which headers they'll pass, in which case they +need to be configured explicitly (see the mention of `Git-Protocol` in +the Apache config from the earlier EXAMPLES section). +  The backend process sets GIT_COMMITTER_NAME to '$REMOTE_USER' and  GIT_COMMITTER_EMAIL to '$\{REMOTE_USER}@http.$\{REMOTE_ADDR\}',  ensuring that any reflogs created by 'git-receive-pack' contain some 
diff --git a/git-upload-pack.html b/git-upload-pack.html index 67bf457..90db60e 100644 --- a/git-upload-pack.html +++ b/git-upload-pack.html 
@@ -822,6 +822,23 @@  </div>   </div>   <div class="sect1">  +<h2 id="_environment">ENVIRONMENT</h2>  +<div class="sectionbody">  +<div class="dlist"><dl>  +<dt class="hdlist1">  +<code>GIT_PROTOCOL</code>  +</dt>  +<dd>  +<p>  + Internal variable used for handshaking the wire protocol. Server  + admins may need to configure some transports to allow this  + variable to be passed. See the discussion in <a href="git.html">git(1)</a>.  +</p>  +</dd>  +</dl></div>  +</div>  +</div>  +<div class="sect1">   <h2 id="_see_also">SEE ALSO</h2>   <div class="sectionbody">   <div class="paragraph"><p><a href="gitnamespaces.html">gitnamespaces(7)</a></p></div>  @@ -838,7 +855,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-09-20 15:44:03 PDT  + 2021-09-23 14:33:59 PDT   </div>   </div>   </body>  
diff --git a/git-upload-pack.txt b/git-upload-pack.txt index 739416e..8f87b23 100644 --- a/git-upload-pack.txt +++ b/git-upload-pack.txt 
@@ -48,6 +48,14 @@  <directory>:: 	The repository to sync from.   +ENVIRONMENT +----------- + +`GIT_PROTOCOL`:: +	Internal variable used for handshaking the wire protocol. Server +	admins may need to configure some transports to allow this +	variable to be passed. See the discussion in linkgit:git[1]. +  SEE ALSO  --------  linkgit:gitnamespaces[7] 
diff --git a/git-version.html b/git-version.html new file mode 100644 index 0000000..96e0150 --- /dev/null +++ b/git-version.html 
@@ -0,0 +1,796 @@ +<?xml version="1.0" encoding="UTF-8"?>  +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"  + "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">  +<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">  +<head>  +<meta http-equiv="Content-Type" content="application/xhtml+xml; charset=UTF-8" />  +<meta name="generator" content="AsciiDoc 9.0.0rc2" />  +<title>git-version(1)</title>  +<style type="text/css">  +/* Shared CSS for AsciiDoc xhtml11 and html5 backends */  +  +/* Default font. */  +body {  + font-family: Georgia,serif;  +}  +  +/* Title font. */  +h1, h2, h3, h4, h5, h6,  +div.title, caption.title,  +thead, p.table.header,  +#toctitle,  +#author, #revnumber, #revdate, #revremark,  +#footer {  + font-family: Arial,Helvetica,sans-serif;  +}  +  +body {  + margin: 1em 5% 1em 5%;  +}  +  +a {  + color: blue;  + text-decoration: underline;  +}  +a:visited {  + color: fuchsia;  +}  +  +em {  + font-style: italic;  + color: navy;  +}  +  +strong {  + font-weight: bold;  + color: #083194;  +}  +  +h1, h2, h3, h4, h5, h6 {  + color: #527bbd;  + margin-top: 1.2em;  + margin-bottom: 0.5em;  + line-height: 1.3;  +}  +  +h1, h2, h3 {  + border-bottom: 2px solid silver;  +}  +h2 {  + padding-top: 0.5em;  +}  +h3 {  + float: left;  +}  +h3 + * {  + clear: left;  +}  +h5 {  + font-size: 1.0em;  +}  +  +div.sectionbody {  + margin-left: 0;  +}  +  +hr {  + border: 1px solid silver;  +}  +  +p {  + margin-top: 0.5em;  + margin-bottom: 0.5em;  +}  +  +ul, ol, li > p {  + margin-top: 0;  +}  +ul > li { color: #aaa; }  +ul > li > * { color: black; }  +  +.monospaced, code, pre {  + font-family: "Courier New", Courier, monospace;  + font-size: inherit;  + color: navy;  + padding: 0;  + margin: 0;  +}  +pre {  + white-space: pre-wrap;  +}  +  +#author {  + color: #527bbd;  + font-weight: bold;  + font-size: 1.1em;  +}  +#email {  +}  +#revnumber, #revdate, #revremark {  +}  +  +#footer {  + font-size: small;  + border-top: 2px solid silver;  + padding-top: 0.5em;  + margin-top: 4.0em;  +}  +#footer-text {  + float: left;  + padding-bottom: 0.5em;  +}  +#footer-badges {  + float: right;  + padding-bottom: 0.5em;  +}  +  +#preamble {  + margin-top: 1.5em;  + margin-bottom: 1.5em;  +}  +div.imageblock, div.exampleblock, div.verseblock,  +div.quoteblock, div.literalblock, div.listingblock, div.sidebarblock,  +div.admonitionblock {  + margin-top: 1.0em;  + margin-bottom: 1.5em;  +}  +div.admonitionblock {  + margin-top: 2.0em;  + margin-bottom: 2.0em;  + margin-right: 10%;  + color: #606060;  +}  +  +div.content { /* Block element content. */  + padding: 0;  +}  +  +/* Block element titles. */  +div.title, caption.title {  + color: #527bbd;  + font-weight: bold;  + text-align: left;  + margin-top: 1.0em;  + margin-bottom: 0.5em;  +}  +div.title + * {  + margin-top: 0;  +}  +  +td div.title:first-child {  + margin-top: 0.0em;  +}  +div.content div.title:first-child {  + margin-top: 0.0em;  +}  +div.content + div.title {  + margin-top: 0.0em;  +}  +  +div.sidebarblock > div.content {  + background: #ffffee;  + border: 1px solid #dddddd;  + border-left: 4px solid #f0f0f0;  + padding: 0.5em;  +}  +  +div.listingblock > div.content {  + border: 1px solid #dddddd;  + border-left: 5px solid #f0f0f0;  + background: #f8f8f8;  + padding: 0.5em;  +}  +  +div.quoteblock, div.verseblock {  + padding-left: 1.0em;  + margin-left: 1.0em;  + margin-right: 10%;  + border-left: 5px solid #f0f0f0;  + color: #888;  +}  +  +div.quoteblock > div.attribution {  + padding-top: 0.5em;  + text-align: right;  +}  +  +div.verseblock > pre.content {  + font-family: inherit;  + font-size: inherit;  +}  +div.verseblock > div.attribution {  + padding-top: 0.75em;  + text-align: left;  +}  +/* DEPRECATED: Pre version 8.2.7 verse style literal block. */  +div.verseblock + div.attribution {  + text-align: left;  +}  +  +div.admonitionblock .icon {  + vertical-align: top;  + font-size: 1.1em;  + font-weight: bold;  + text-decoration: underline;  + color: #527bbd;  + padding-right: 0.5em;  +}  +div.admonitionblock td.content {  + padding-left: 0.5em;  + border-left: 3px solid #dddddd;  +}  +  +div.exampleblock > div.content {  + border-left: 3px solid #dddddd;  + padding-left: 0.5em;  +}  +  +div.imageblock div.content { padding-left: 0; }  +span.image img { border-style: none; vertical-align: text-bottom; }  +a.image:visited { color: white; }  +  +dl {  + margin-top: 0.8em;  + margin-bottom: 0.8em;  +}  +dt {  + margin-top: 0.5em;  + margin-bottom: 0;  + font-style: normal;  + color: navy;  +}  +dd > *:first-child {  + margin-top: 0.1em;  +}  +  +ul, ol {  + list-style-position: outside;  +}  +ol.arabic {  + list-style-type: decimal;  +}  +ol.loweralpha {  + list-style-type: lower-alpha;  +}  +ol.upperalpha {  + list-style-type: upper-alpha;  +}  +ol.lowerroman {  + list-style-type: lower-roman;  +}  +ol.upperroman {  + list-style-type: upper-roman;  +}  +  +div.compact ul, div.compact ol,  +div.compact p, div.compact p,  +div.compact div, div.compact div {  + margin-top: 0.1em;  + margin-bottom: 0.1em;  +}  +  +tfoot {  + font-weight: bold;  +}  +td > div.verse {  + white-space: pre;  +}  +  +div.hdlist {  + margin-top: 0.8em;  + margin-bottom: 0.8em;  +}  +div.hdlist tr {  + padding-bottom: 15px;  +}  +dt.hdlist1.strong, td.hdlist1.strong {  + font-weight: bold;  +}  +td.hdlist1 {  + vertical-align: top;  + font-style: normal;  + padding-right: 0.8em;  + color: navy;  +}  +td.hdlist2 {  + vertical-align: top;  +}  +div.hdlist.compact tr {  + margin: 0;  + padding-bottom: 0;  +}  +  +.comment {  + background: yellow;  +}  +  +.footnote, .footnoteref {  + font-size: 0.8em;  +}  +  +span.footnote, span.footnoteref {  + vertical-align: super;  +}  +  +#footnotes {  + margin: 20px 0 20px 0;  + padding: 7px 0 0 0;  +}  +  +#footnotes div.footnote {  + margin: 0 0 5px 0;  +}  +  +#footnotes hr {  + border: none;  + border-top: 1px solid silver;  + height: 1px;  + text-align: left;  + margin-left: 0;  + width: 20%;  + min-width: 100px;  +}  +  +div.colist td {  + padding-right: 0.5em;  + padding-bottom: 0.3em;  + vertical-align: top;  +}  +div.colist td img {  + margin-top: 0.3em;  +}  +  +@media print {  + #footer-badges { display: none; }  +}  +  +#toc {  + margin-bottom: 2.5em;  +}  +  +#toctitle {  + color: #527bbd;  + font-size: 1.1em;  + font-weight: bold;  + margin-top: 1.0em;  + margin-bottom: 0.1em;  +}  +  +div.toclevel0, div.toclevel1, div.toclevel2, div.toclevel3, div.toclevel4 {  + margin-top: 0;  + margin-bottom: 0;  +}  +div.toclevel2 {  + margin-left: 2em;  + font-size: 0.9em;  +}  +div.toclevel3 {  + margin-left: 4em;  + font-size: 0.9em;  +}  +div.toclevel4 {  + margin-left: 6em;  + font-size: 0.9em;  +}  +  +span.aqua { color: aqua; }  +span.black { color: black; }  +span.blue { color: blue; }  +span.fuchsia { color: fuchsia; }  +span.gray { color: gray; }  +span.green { color: green; }  +span.lime { color: lime; }  +span.maroon { color: maroon; }  +span.navy { color: navy; }  +span.olive { color: olive; }  +span.purple { color: purple; }  +span.red { color: red; }  +span.silver { color: silver; }  +span.teal { color: teal; }  +span.white { color: white; }  +span.yellow { color: yellow; }  +  +span.aqua-background { background: aqua; }  +span.black-background { background: black; }  +span.blue-background { background: blue; }  +span.fuchsia-background { background: fuchsia; }  +span.gray-background { background: gray; }  +span.green-background { background: green; }  +span.lime-background { background: lime; }  +span.maroon-background { background: maroon; }  +span.navy-background { background: navy; }  +span.olive-background { background: olive; }  +span.purple-background { background: purple; }  +span.red-background { background: red; }  +span.silver-background { background: silver; }  +span.teal-background { background: teal; }  +span.white-background { background: white; }  +span.yellow-background { background: yellow; }  +  +span.big { font-size: 2em; }  +span.small { font-size: 0.6em; }  +  +span.underline { text-decoration: underline; }  +span.overline { text-decoration: overline; }  +span.line-through { text-decoration: line-through; }  +  +div.unbreakable { page-break-inside: avoid; }  +  +  +/*  + * xhtml11 specific  + *  + * */  +  +div.tableblock {  + margin-top: 1.0em;  + margin-bottom: 1.5em;  +}  +div.tableblock > table {  + border: 3px solid #527bbd;  +}  +thead, p.table.header {  + font-weight: bold;  + color: #527bbd;  +}  +p.table {  + margin-top: 0;  +}  +/* Because the table frame attribute is overridden by CSS in most browsers. */  +div.tableblock > table[frame="void"] {  + border-style: none;  +}  +div.tableblock > table[frame="hsides"] {  + border-left-style: none;  + border-right-style: none;  +}  +div.tableblock > table[frame="vsides"] {  + border-top-style: none;  + border-bottom-style: none;  +}  +  +  +/*  + * html5 specific  + *  + * */  +  +table.tableblock {  + margin-top: 1.0em;  + margin-bottom: 1.5em;  +}  +thead, p.tableblock.header {  + font-weight: bold;  + color: #527bbd;  +}  +p.tableblock {  + margin-top: 0;  +}  +table.tableblock {  + border-width: 3px;  + border-spacing: 0px;  + border-style: solid;  + border-color: #527bbd;  + border-collapse: collapse;  +}  +th.tableblock, td.tableblock {  + border-width: 1px;  + padding: 4px;  + border-style: solid;  + border-color: #527bbd;  +}  +  +table.tableblock.frame-topbot {  + border-left-style: hidden;  + border-right-style: hidden;  +}  +table.tableblock.frame-sides {  + border-top-style: hidden;  + border-bottom-style: hidden;  +}  +table.tableblock.frame-none {  + border-style: hidden;  +}  +  +th.tableblock.halign-left, td.tableblock.halign-left {  + text-align: left;  +}  +th.tableblock.halign-center, td.tableblock.halign-center {  + text-align: center;  +}  +th.tableblock.halign-right, td.tableblock.halign-right {  + text-align: right;  +}  +  +th.tableblock.valign-top, td.tableblock.valign-top {  + vertical-align: top;  +}  +th.tableblock.valign-middle, td.tableblock.valign-middle {  + vertical-align: middle;  +}  +th.tableblock.valign-bottom, td.tableblock.valign-bottom {  + vertical-align: bottom;  +}  +  +  +/*  + * manpage specific  + *  + * */  +  +body.manpage h1 {  + padding-top: 0.5em;  + padding-bottom: 0.5em;  + border-top: 2px solid silver;  + border-bottom: 2px solid silver;  +}  +body.manpage h2 {  + border-style: none;  +}  +body.manpage div.sectionbody {  + margin-left: 3em;  +}  +  +@media print {  + body.manpage div#toc { display: none; }  +}  +  +  +</style>  +<script type="text/javascript">  +/*<![CDATA[*/  +var asciidoc = { // Namespace.  +  +/////////////////////////////////////////////////////////////////////  +// Table Of Contents generator  +/////////////////////////////////////////////////////////////////////  +  +/* Author: Mihai Bazon, September 2002  + * http://students.infoiasi.ro/~mishoo  + *  + * Table Of Content generator  + * Version: 0.4  + *  + * Feel free to use this script under the terms of the GNU General Public  + * License, as long as you do not remove or alter this notice.  + */  +  + /* modified by Troy D. Hanson, September 2006. License: GPL */  + /* modified by Stuart Rackham, 2006, 2009. License: GPL */  +  +// toclevels = 1..4.  +toc: function (toclevels) {  +  + function getText(el) {  + var text = "";  + for (var i = el.firstChild; i != null; i = i.nextSibling) {  + if (i.nodeType == 3 /* Node.TEXT_NODE */) // IE doesn't speak constants.  + text += i.data;  + else if (i.firstChild != null)  + text += getText(i);  + }  + return text;  + }  +  + function TocEntry(el, text, toclevel) {  + this.element = el;  + this.text = text;  + this.toclevel = toclevel;  + }  +  + function tocEntries(el, toclevels) {  + var result = new Array;  + var re = new RegExp('[hH]([1-'+(toclevels+1)+'])');  + // Function that scans the DOM tree for header elements (the DOM2  + // nodeIterator API would be a better technique but not supported by all  + // browsers).  + var iterate = function (el) {  + for (var i = el.firstChild; i != null; i = i.nextSibling) {  + if (i.nodeType == 1 /* Node.ELEMENT_NODE */) {  + var mo = re.exec(i.tagName);  + if (mo && (i.getAttribute("class") || i.getAttribute("className")) != "float") {  + result[result.length] = new TocEntry(i, getText(i), mo[1]-1);  + }  + iterate(i);  + }  + }  + }  + iterate(el);  + return result;  + }  +  + var toc = document.getElementById("toc");  + if (!toc) {  + return;  + }  +  + // Delete existing TOC entries in case we're reloading the TOC.  + var tocEntriesToRemove = [];  + var i;  + for (i = 0; i < toc.childNodes.length; i++) {  + var entry = toc.childNodes[i];  + if (entry.nodeName.toLowerCase() == 'div'  + && entry.getAttribute("class")  + && entry.getAttribute("class").match(/^toclevel/))  + tocEntriesToRemove.push(entry);  + }  + for (i = 0; i < tocEntriesToRemove.length; i++) {  + toc.removeChild(tocEntriesToRemove[i]);  + }  +  + // Rebuild TOC entries.  + var entries = tocEntries(document.getElementById("content"), toclevels);  + for (var i = 0; i < entries.length; ++i) {  + var entry = entries[i];  + if (entry.element.id == "")  + entry.element.id = "_toc_" + i;  + var a = document.createElement("a");  + a.href = "#" + entry.element.id;  + a.appendChild(document.createTextNode(entry.text));  + var div = document.createElement("div");  + div.appendChild(a);  + div.className = "toclevel" + entry.toclevel;  + toc.appendChild(div);  + }  + if (entries.length == 0)  + toc.parentNode.removeChild(toc);  +},  +  +  +/////////////////////////////////////////////////////////////////////  +// Footnotes generator  +/////////////////////////////////////////////////////////////////////  +  +/* Based on footnote generation code from:  + * http://www.brandspankingnew.net/archive/2005/07/format_footnote.html  + */  +  +footnotes: function () {  + // Delete existing footnote entries in case we're reloading the footnodes.  + var i;  + var noteholder = document.getElementById("footnotes");  + if (!noteholder) {  + return;  + }  + var entriesToRemove = [];  + for (i = 0; i < noteholder.childNodes.length; i++) {  + var entry = noteholder.childNodes[i];  + if (entry.nodeName.toLowerCase() == 'div' && entry.getAttribute("class") == "footnote")  + entriesToRemove.push(entry);  + }  + for (i = 0; i < entriesToRemove.length; i++) {  + noteholder.removeChild(entriesToRemove[i]);  + }  +  + // Rebuild footnote entries.  + var cont = document.getElementById("content");  + var spans = cont.getElementsByTagName("span");  + var refs = {};  + var n = 0;  + for (i=0; i<spans.length; i++) {  + if (spans[i].className == "footnote") {  + n++;  + var note = spans[i].getAttribute("data-note");  + if (!note) {  + // Use [\s\S] in place of . so multi-line matches work.  + // Because JavaScript has no s (dotall) regex flag.  + note = spans[i].innerHTML.match(/\s*\[([\s\S]*)]\s*/)[1];  + spans[i].innerHTML =  + "[<a id='_footnoteref_" + n + "' href='#_footnote_" + n +  + "' title='View footnote' class='footnote'>" + n + "</a>]";  + spans[i].setAttribute("data-note", note);  + }  + noteholder.innerHTML +=  + "<div class='footnote' id='_footnote_" + n + "'>" +  + "<a href='#_footnoteref_" + n + "' title='Return to text'>" +  + n + "</a>. " + note + "</div>";  + var id =spans[i].getAttribute("id");  + if (id != null) refs["#"+id] = n;  + }  + }  + if (n == 0)  + noteholder.parentNode.removeChild(noteholder);  + else {  + // Process footnoterefs.  + for (i=0; i<spans.length; i++) {  + if (spans[i].className == "footnoteref") {  + var href = spans[i].getElementsByTagName("a")[0].getAttribute("href");  + href = href.match(/#.*/)[0]; // Because IE return full URL.  + n = refs[href];  + spans[i].innerHTML =  + "[<a href='#_footnote_" + n +  + "' title='View footnote' class='footnote'>" + n + "</a>]";  + }  + }  + }  +},  +  +install: function(toclevels) {  + var timerId;  +  + function reinstall() {  + asciidoc.footnotes();  + if (toclevels) {  + asciidoc.toc(toclevels);  + }  + }  +  + function reinstallAndRemoveTimer() {  + clearInterval(timerId);  + reinstall();  + }  +  + timerId = setInterval(reinstall, 500);  + if (document.addEventListener)  + document.addEventListener("DOMContentLoaded", reinstallAndRemoveTimer, false);  + else  + window.onload = reinstallAndRemoveTimer;  +}  +  +}  +asciidoc.install();  +/*]]>*/  +</script>  +</head>  +<body class="manpage">  +<div id="header">  +<h1>  +git-version(1) Manual Page  +</h1>  +<h2>NAME</h2>  +<div class="sectionbody">  +<p>git-version -  + Display version information about Git  +</p>  +</div>  +</div>  +<div id="content">  +<div class="sect1">  +<h2 id="_synopsis">SYNOPSIS</h2>  +<div class="sectionbody">  +<div class="verseblock">  +<pre class="content"><em>git version</em> [--build-options]</pre>  +<div class="attribution">  +</div></div>  +</div>  +</div>  +<div class="sect1">  +<h2 id="_description">DESCRIPTION</h2>  +<div class="sectionbody">  +<div class="paragraph"><p>With no options given, the version of <em>git</em> is printed on the standard output.</p></div>  +<div class="paragraph"><p>Note that <code>git --version</code> is identical to <code>git version</code> because the  +former is internally converted into the latter.</p></div>  +</div>  +</div>  +<div class="sect1">  +<h2 id="_options">OPTIONS</h2>  +<div class="sectionbody">  +<div class="dlist"><dl>  +<dt class="hdlist1">  +--build-options  +</dt>  +<dd>  +<p>  + Include additional information about how git was built for diagnostic  + purposes.  +</p>  +</dd>  +</dl></div>  +</div>  +</div>  +<div class="sect1">  +<h2 id="_git">GIT</h2>  +<div class="sectionbody">  +<div class="paragraph"><p>Part of the <a href="git.html">git(1)</a> suite</p></div>  +</div>  +</div>  +</div>  +<div id="footnotes"><hr /></div>  +<div id="footer">  +<div id="footer-text">  +Last updated  + 2021-09-23 14:33:59 PDT  +</div>  +</div>  +</body>  +</html>  
diff --git a/git-version.txt b/git-version.txt new file mode 100644 index 0000000..80fa775 --- /dev/null +++ b/git-version.txt 
@@ -0,0 +1,28 @@ +git-version(1) +============== + +NAME +---- +git-version - Display version information about Git + +SYNOPSIS +-------- +[verse] +'git version' [--build-options] + +DESCRIPTION +----------- +With no options given, the version of 'git' is printed on the standard output. + +Note that `git --version` is identical to `git version` because the +former is internally converted into the latter. + +OPTIONS +------- +--build-options:: +	Include additional information about how git was built for diagnostic +	purposes. + +GIT +--- +Part of the linkgit:git[1] suite 
diff --git a/git.html b/git.html index 7396983..0346349 100644 --- a/git.html +++ b/git.html 
@@ -789,6 +789,9 @@  <p>   Prints the Git suite version that the <em>git</em> program came from.   </p>  +<div class="paragraph"><p>This option is internaly converted to <code>git version ...</code> and accepts  +the same options as the <a href="git-version.html">git-version(1)</a> command. If <code>--help</code> is  +also given, it takes precedence over <code>--version</code>.</p></div>   </dd>   <dt class="hdlist1">   --help  @@ -3463,6 +3466,19 @@  <em>key[=value]</em>. Presence of unknown keys and values must be   ignored.   </p>  +<div class="paragraph"><p>Note that servers may need to be configured to allow this variable to  +pass over some transports. It will be propagated automatically when  +accessing local repositories (i.e., <code>file://</code> or a filesystem path), as  +well as over the <code>git://</code> protocol. For git-over-http, it should work  +automatically in most configurations, but see the discussion in  +<a href="git-http-backend.html">git-http-backend(1)</a>. For git-over-ssh, the ssh server may need  +to be configured to allow clients to pass this variable (e.g., by using  +<code>AcceptEnv GIT_PROTOCOL</code> with OpenSSH).</p></div>  +<div class="paragraph"><p>This configuration is optional. If the variable is not propagated, then  +clients will fall back to the original "v0" protocol (but may miss out  +on some performance improvements or features). This variable currently  +only affects clones and fetches; it is not yet used for pushes (but may  +be in the future).</p></div>   </dd>   <dt class="hdlist1">   <code>GIT_OPTIONAL_LOCKS</code>  @@ -3630,7 +3646,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-05-06 21:22:01 PDT  + 2021-09-23 14:33:59 PDT   </div>   </div>   </body>  
diff --git a/git.txt b/git.txt index 6dd241e..abace9e 100644 --- a/git.txt +++ b/git.txt 
@@ -41,6 +41,10 @@  -------  --version:: 	Prints the Git suite version that the 'git' program came from. ++ +This option is internaly converted to `git version ...` and accepts +the same options as the linkgit:git-version[1] command. If `--help` is +also given, it takes precedence over `--version`.    --help:: 	Prints the synopsis and a list of the most commonly used @@ -894,6 +898,21 @@ 	Contains a colon ':' separated list of keys with optional values 	'key[=value]'. Presence of unknown keys and values must be 	ignored. ++ +Note that servers may need to be configured to allow this variable to +pass over some transports. It will be propagated automatically when +accessing local repositories (i.e., `file://` or a filesystem path), as +well as over the `git://` protocol. For git-over-http, it should work +automatically in most configurations, but see the discussion in +linkgit:git-http-backend[1]. For git-over-ssh, the ssh server may need +to be configured to allow clients to pass this variable (e.g., by using +`AcceptEnv GIT_PROTOCOL` with OpenSSH). ++ +This configuration is optional. If the variable is not propagated, then +clients will fall back to the original "v0" protocol (but may miss out +on some performance improvements or features). This variable currently +only affects clones and fetches; it is not yet used for pushes (but may +be in the future).    `GIT_OPTIONAL_LOCKS`:: 	If set to `0`, Git will complete any requested operation without 
diff --git a/howto/coordinate-embargoed-releases.html b/howto/coordinate-embargoed-releases.html index 6eb0fef..084565c 100644 --- a/howto/coordinate-embargoed-releases.html +++ b/howto/coordinate-embargoed-releases.html 
@@ -873,7 +873,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-09-20 15:44:09 PDT  + 2021-09-23 14:34:35 PDT   </div>   </div>   </body>  
diff --git a/howto/keep-canonical-history-correct.html b/howto/keep-canonical-history-correct.html index c9a6f0a..0e03702 100644 --- a/howto/keep-canonical-history-correct.html +++ b/howto/keep-canonical-history-correct.html 
@@ -938,7 +938,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-09-20 15:44:09 PDT  + 2021-09-23 14:34:35 PDT   </div>   </div>   </body>  
diff --git a/howto/maintain-git.html b/howto/maintain-git.html index 7ece0f7..b1b1b29 100644 --- a/howto/maintain-git.html +++ b/howto/maintain-git.html 
@@ -1469,7 +1469,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-09-20 15:44:09 PDT  + 2021-09-23 14:34:35 PDT   </div>   </div>   </body>  
diff --git a/howto/new-command.html b/howto/new-command.html index c32c479..7f04f7f 100644 --- a/howto/new-command.html +++ b/howto/new-command.html 
@@ -863,7 +863,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-09-20 15:44:07 PDT  + 2021-09-23 14:34:33 PDT   </div>   </div>   </body>  
diff --git a/howto/rebase-from-internal-branch.html b/howto/rebase-from-internal-branch.html index 449fa0e..e2b5dfb 100644 --- a/howto/rebase-from-internal-branch.html +++ b/howto/rebase-from-internal-branch.html 
@@ -895,7 +895,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-09-20 15:44:09 PDT  + 2021-09-23 14:34:35 PDT   </div>   </div>   </body>  
diff --git a/howto/rebuild-from-update-hook.html b/howto/rebuild-from-update-hook.html index 10717a0..93873d8 100644 --- a/howto/rebuild-from-update-hook.html +++ b/howto/rebuild-from-update-hook.html 
@@ -847,7 +847,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-09-20 15:44:09 PDT  + 2021-09-23 14:34:35 PDT   </div>   </div>   </body>  
diff --git a/howto/recover-corrupted-blob-object.html b/howto/recover-corrupted-blob-object.html index 6167e7e..37154cd 100644 --- a/howto/recover-corrupted-blob-object.html +++ b/howto/recover-corrupted-blob-object.html 
@@ -880,7 +880,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-09-20 15:44:08 PDT  + 2021-09-23 14:34:34 PDT   </div>   </div>   </body>  
diff --git a/howto/recover-corrupted-object-harder.html b/howto/recover-corrupted-object-harder.html index cf92f20..b8eb35c 100644 --- a/howto/recover-corrupted-object-harder.html +++ b/howto/recover-corrupted-object-harder.html 
@@ -1189,7 +1189,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-09-20 15:44:08 PDT  + 2021-09-23 14:34:35 PDT   </div>   </div>   </body>  
diff --git a/howto/revert-a-faulty-merge.html b/howto/revert-a-faulty-merge.html index 18c2f1f..5692ea9 100644 --- a/howto/revert-a-faulty-merge.html +++ b/howto/revert-a-faulty-merge.html 
@@ -1025,7 +1025,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-09-20 15:44:08 PDT  + 2021-09-23 14:34:34 PDT   </div>   </div>   </body>  
diff --git a/howto/revert-branch-rebase.html b/howto/revert-branch-rebase.html index 02aa91d..a811057 100644 --- a/howto/revert-branch-rebase.html +++ b/howto/revert-branch-rebase.html 
@@ -907,7 +907,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-09-20 15:44:07 PDT  + 2021-09-23 14:34:33 PDT   </div>   </div>   </body>  
diff --git a/howto/separating-topic-branches.html b/howto/separating-topic-branches.html index 78b3dcb..53cebee 100644 --- a/howto/separating-topic-branches.html +++ b/howto/separating-topic-branches.html 
@@ -841,7 +841,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-09-20 15:44:08 PDT  + 2021-09-23 14:34:34 PDT   </div>   </div>   </body>  
diff --git a/howto/setup-git-server-over-http.html b/howto/setup-git-server-over-http.html index 6f534ef..c845a9a 100644 --- a/howto/setup-git-server-over-http.html +++ b/howto/setup-git-server-over-http.html 
@@ -1071,7 +1071,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-09-20 15:44:08 PDT  + 2021-09-23 14:34:34 PDT   </div>   </div>   </body>  
diff --git a/howto/update-hook-example.html b/howto/update-hook-example.html index 5a38870..896b43e 100644 --- a/howto/update-hook-example.html +++ b/howto/update-hook-example.html 
@@ -930,7 +930,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-09-20 15:44:08 PDT  + 2021-09-23 14:34:34 PDT   </div>   </div>   </body>  
diff --git a/howto/use-git-daemon.html b/howto/use-git-daemon.html index bffd8a0..a5e08a3 100644 --- a/howto/use-git-daemon.html +++ b/howto/use-git-daemon.html 
@@ -791,7 +791,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-09-20 15:44:07 PDT  + 2021-09-23 14:34:33 PDT   </div>   </div>   </body>  
diff --git a/howto/using-merge-subtree.html b/howto/using-merge-subtree.html index 1f7792b..75e52f5 100644 --- a/howto/using-merge-subtree.html +++ b/howto/using-merge-subtree.html 
@@ -848,7 +848,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-09-20 15:44:07 PDT  + 2021-09-23 14:34:33 PDT   </div>   </div>   </body>  
diff --git a/howto/using-signed-tag-in-pull-request.html b/howto/using-signed-tag-in-pull-request.html index 3f79105..728a650 100644 --- a/howto/using-signed-tag-in-pull-request.html +++ b/howto/using-signed-tag-in-pull-request.html 
@@ -952,7 +952,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-09-20 15:44:07 PDT  + 2021-09-23 14:34:33 PDT   </div>   </div>   </body>  
diff --git a/technical/api-parse-options.html b/technical/api-parse-options.html index 16293e2..93e5aad 100644 --- a/technical/api-parse-options.html +++ b/technical/api-parse-options.html 
@@ -1103,16 +1103,6 @@  </p>   </dd>   <dt class="hdlist1">  -<code>OPT_ARGUMENT(long, &amp;int_var, description)</code>  -</dt>  -<dd>  -<p>  - Introduce a long-option argument that will be kept in <code>argv[]</code>.  - If this option was seen, <code>int_var</code> will be set to one (except  - if a <code>NULL</code> pointer was passed).  -</p>  -</dd>  -<dt class="hdlist1">   <code>OPT_NUMBER_CALLBACK(&amp;var, description, func_ptr)</code>   </dt>   <dd>  @@ -1290,7 +1280,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2020-08-10 16:45:05 PDT  + 2021-09-23 14:33:59 PDT   </div>   </div>   </body>  
diff --git a/technical/api-parse-options.txt b/technical/api-parse-options.txt index 5a60bbf..acfd5dc 100644 --- a/technical/api-parse-options.txt +++ b/technical/api-parse-options.txt 
@@ -198,11 +198,6 @@ 	The filename will be prefixed by passing the filename along with 	the prefix argument of `parse_options()` to `prefix_filename()`.   -`OPT_ARGUMENT(long, &int_var, description)`:: -	Introduce a long-option argument that will be kept in `argv[]`. -	If this option was seen, `int_var` will be set to one (except -	if a `NULL` pointer was passed). -  `OPT_NUMBER_CALLBACK(&var, description, func_ptr)`:: 	Recognize numerical options like -123 and feed the integer as 	if it was an argument to the function given by `func_ptr`. 
diff --git a/technical/protocol-v2.html b/technical/protocol-v2.html index 7e498db..a925fad 100644 --- a/technical/protocol-v2.html +++ b/technical/protocol-v2.html 
@@ -818,7 +818,8 @@  <div class="paragraph"><p>In general a client can request to speak protocol v2 by sending   <code>version=2</code> through the respective side-channel for the transport being   used which inevitably sets <code>GIT_PROTOCOL</code>. More information can be  -found in <code>pack-protocol.txt</code> and <code>http-protocol.txt</code>. In all cases the  +found in <code>pack-protocol.txt</code> and <code>http-protocol.txt</code>, as well as the  +<code>GIT_PROTOCOL</code> definition in <code>git.txt</code>. In all cases the   response from the server is the capability advertisement.</p></div>   <div class="sect2">   <h3 id="_git_transport">Git Transport</h3>  @@ -832,7 +833,9 @@  <div class="sect2">   <h3 id="_ssh_and_file_transport">SSH and File Transport</h3>   <div class="paragraph"><p>When using either the ssh:// or file:// transport, the GIT_PROTOCOL  -environment variable must be set explicitly to include "version=2".</p></div>  +environment variable must be set explicitly to include "version=2".  +The server may need to be configured to allow this environment variable  +to pass.</p></div>   </div>   <div class="sect2">   <h3 id="_http_transport">HTTP Transport</h3>  @@ -858,6 +861,8 @@  <code>$GIT_URL/git-upload-pack</code>. (This works the same for git-receive-pack).</p></div>   <div class="paragraph"><p>Uses the <code>--http-backend-info-refs</code> option to   <a href="../git-upload-pack.html">git-upload-pack(1)</a>.</p></div>  +<div class="paragraph"><p>The server may need to be configured to pass this header&#8217;s contents via  +the <code>GIT_PROTOCOL</code> variable. See the discussion in <code>git-http-backend.txt</code>.</p></div>   </div>   </div>   </div>  @@ -1465,7 +1470,7 @@  <div id="footer">   <div id="footer-text">   Last updated  - 2021-09-20 15:44:03 PDT  + 2021-09-23 14:33:59 PDT   </div>   </div>   </body>  
diff --git a/technical/protocol-v2.txt b/technical/protocol-v2.txt index 213538f..59b86fc 100644 --- a/technical/protocol-v2.txt +++ b/technical/protocol-v2.txt 
@@ -42,7 +42,8 @@  In general a client can request to speak protocol v2 by sending  `version=2` through the respective side-channel for the transport being  used which inevitably sets `GIT_PROTOCOL`. More information can be -found in `pack-protocol.txt` and `http-protocol.txt`. In all cases the +found in `pack-protocol.txt` and `http-protocol.txt`, as well as the +`GIT_PROTOCOL` definition in `git.txt`. In all cases the  response from the server is the capability advertisement.    Git Transport @@ -58,6 +59,8 @@    When using either the ssh:// or file:// transport, the GIT_PROTOCOL  environment variable must be set explicitly to include "version=2". +The server may need to be configured to allow this environment variable +to pass.    HTTP Transport  ~~~~~~~~~~~~~~ @@ -84,6 +87,9 @@  Uses the `--http-backend-info-refs` option to  linkgit:git-upload-pack[1].   +The server may need to be configured to pass this header's contents via +the `GIT_PROTOCOL` variable. See the discussion in `git-http-backend.txt`. +  Capability Advertisement  ------------------------